package com.csl.smvc.push;

import cn.jiguang.common.resp.APIConnectionException;
import cn.jiguang.common.resp.APIRequestException;
import cn.jpush.api.JPushClient;
import cn.jpush.api.push.PushResult;
import cn.jpush.api.push.model.Message;
import cn.jpush.api.push.model.Options;
import cn.jpush.api.push.model.Platform;
import cn.jpush.api.push.model.PushPayload;
import cn.jpush.api.push.model.audience.Audience;
import cn.jpush.api.push.model.notification.AndroidNotification;
import cn.jpush.api.push.model.notification.IosNotification;
import cn.jpush.api.push.model.notification.Notification;

/**
 * 极光推送工具类
 * @author liucs
 *
 */
public class JpushClientUtil {
	private static String masterSecret="7b630f91c1a9c90360860550"; //此处是masterSecret
	private static String appKey="2961a11b5606263930068ef1"; //此处是appkey
	
	private static JPushClient jPushClient = new JPushClient(masterSecret,appKey);
	
	
	/**
       * 推送给设备标识参数的用户
       * @param registrationId 设备标识
       * @param notification_title 通知内容标题
       * @param msg_title 消息内容标题
       * @param msg_content 消息内容
       * @param extrasparam 扩展字段
       * @return 0推送失败，1推送成功
     */
      public static int sendToRegistrationId( String registrationId,String notification_title, String msg_title, String msg_content, String extrasparam) {
          int result = 0;
         try {
              PushPayload pushPayload= JpushClientUtil.buildPushObject_all_registrationId_alertWithTitle(registrationId,notification_title,msg_title,msg_content,extrasparam);
              System.out.println(pushPayload);
             PushResult pushResult=jPushClient.sendPush(pushPayload);
              System.out.println(pushResult);
              if(pushResult.getResponseCode()==200){
                  result=1;
              }
          } catch (APIConnectionException e) {
              e.printStackTrace();
   
          } catch (APIRequestException e) {
              e.printStackTrace();
          }
   
           return result;
      }

      /**
       * 发送给所有安卓用户
       * @param notification_title 通知内容标题
       * @param msg_title 消息内容标题
       * @param msg_content 消息内容
       * @param extrasparam 扩展字段
       * @return 0 推送失败，1 推送成功
       */
      public static int sendToAllAndroid(String notification_title, String msg_title, String msg_content, String extrasparam) {
    	  int result=0;
    	  try {
    		  PushPayload pushPayload=JpushClientUtil.buildPushObject_android_all_alertWithTitle(
    				  notification_title,msg_title,msg_content,extrasparam);
    		  System.out.println(pushPayload);
    		  PushResult pushResult=jPushClient.sendPush(pushPayload);
    		  System.out.println(pushResult);
    		  if (pushResult.getResponseCode()==200) {
				result=1;
			}
		} catch (Exception e) {
			e.printStackTrace();
		}
    	  return result;
      }
	      
  	/**
        * 发送给所有IOS用户
        * @param notification_title 通知内容标题
        * @param msg_title 消息内容标题
        * @param msg_content 消息内容
        * @param extrasparam 扩展字段
        * @return 0推送失败，1推送成功
      */
       public static int sendToAllIos(String notification_title, String msg_title, String msg_content, String extrasparam) {
           int result = 0;
           try {
               PushPayload pushPayload= JpushClientUtil.buildPushObject_ios_all_alertWithTitle(notification_title,msg_title,msg_content,extrasparam);
               System.out.println(pushPayload);
              PushResult pushResult=jPushClient.sendPush(pushPayload);
               System.out.println(pushResult);
               if(pushResult.getResponseCode()==200){
                   result=1;
               }
           } catch (Exception e) {
    
               e.printStackTrace();
           }
    
            return result;
      }
       
     /**
      * 发送给所有用户
      * @param notification_title 通知内容标题
      * @param msg_title 消息内容标题
      * @param msg_content 消息内容
      * @param extrasparam 扩展字段
      * @return  0推送失败，1推送成功
      */
     public static int sentToAll(String notification_title, String msg_title, String msg_content, String extrasparam) {
    	  int result = 0;
    	           try {
    	               PushPayload pushPayload= JpushClientUtil.buildPushObject_android_and_ios(notification_title,msg_title,msg_content,extrasparam);
    	              System.out.println(pushPayload);
    	               PushResult pushResult=jPushClient.sendPush(pushPayload);
    	               System.out.println(pushResult);
    	               if(pushResult.getResponseCode()==200){
    	                   result=1;
    	               }
    	           } catch (Exception e) {
    	    
    	               e.printStackTrace();
    	           }
    	       return result;
     }
	

	/**
	 * 推送到IOS
	 * @param notification_title
	 * @param msg_title
	 * @param msg_content
	 * @param extrasparam
	 * @return
	 */
	private static PushPayload buildPushObject_ios_all_alertWithTitle(String notification_title, String msg_title,
				String msg_content, String extrasparam) {
		System.out.println("----------buildPushObject_ios_registrationId_alertWithTitle");
         return PushPayload.newBuilder()
                 //指定要推送的平台，all代表当前应用配置了的所有平台，也可以传android等具体平台
                 .setPlatform(Platform.ios())
                 //指定推送的接收对象，all代表所有人，也可以指定已经设置成功的tag或alias或该应应用客户端调用接口获取到的registration id
                 .setAudience(Audience.all())
                 //jpush的通知，android的由jpush直接下发，iOS的由apns服务器下发，Winphone的由mpns下发
                 .setNotification(Notification.newBuilder()
                         //指定当前推送的android通知
                         .addPlatformNotification(IosNotification.newBuilder()
                                 //传一个IosAlert对象，指定apns title、title、subtitle等
                                 .setAlert(notification_title)
                                 //直接传alert
                                 //此项是指定此推送的badge自动加1
                                 .incrBadge(1)
                                 //此字段的值default表示系统默认声音；传sound.caf表示此推送以项目里面打包的sound.caf声音来提醒，
                                 // 如果系统没有此音频则以系统默认声音提醒；此字段如果传空字符串，iOS9及以上的系统是无声音提醒，以下的系统是默认声音
                                 .setSound("sound.caf")
                                 //此字段为透传字段，不会显示在通知栏。用户可以通过此字段来做一些定制需求，如特定的key传要指定跳转的页面（value）
                                 .addExtra("iosNotification extras key",extrasparam)
                                 //此项说明此推送是一个background推送，想了解background看：http://docs.jpush.io/client/ios_tutorials/#ios-7-background-remote-notification
                                // .setContentAvailable(true)
  
                                 .build())
                         .build()
                 )
                 //Platform指定了哪些平台就会像指定平台中符合推送条件的设备进行推送。 jpush的自定义消息，
                 // sdk默认不做任何处理，不会有通知提示。建议看文档http://docs.jpush.io/guideline/faq/的
                 // [通知与自定义消息有什么区别？]了解通知和自定义消息的区别
                 .setMessage(Message.newBuilder()
                         .setMsgContent(msg_content)
                         .setTitle(msg_title)
                         .addExtra("message extras key",extrasparam)
                         .build())
  
                 .setOptions(Options.newBuilder()
                         //此字段的值是用来指定本推送要推送的apns环境，false表示开发，true表示生产；对android和自定义消息无意义
                         .setApnsProduction(false)
                         //此字段是给开发者自己给推送编号，方便推送者分辨推送记录
                         .setSendno(1)
                         //此字段的值是用来指定本推送的离线保存时长，如果不传此字段则默认保存一天，最多指定保留十天，单位为秒
                         .setTimeToLive(86400)
                         .build())
                 .build();
	}

	
	/**
	 * 推送到Andriod
	 * @param notification_title
	 * @param msg_title
	 * @param msg_content
	 * @param extrasparam
	 * @return
	 */
	private static PushPayload buildPushObject_android_all_alertWithTitle(String notification_title,
				String msg_title, String msg_content, String extrasparam) {
		 System.out.println("----------buildPushObject_android_registrationId_alertWithTitle");
		          return PushPayload.newBuilder()
		                  //指定要推送的平台，all代表当前应用配置了的所有平台，也可以传android等具体平台
		                  .setPlatform(Platform.android())
		                  //指定推送的接收对象，all代表所有人，也可以指定已经设置成功的tag或alias或该应应用客户端调用接口获取到的registration id
		                  .setAudience(Audience.all())
		                  //jpush的通知，android的由jpush直接下发，iOS的由apns服务器下发，Winphone的由mpns下发
		                  .setNotification(Notification.newBuilder()
		                          //指定当前推送的android通知
		                          .addPlatformNotification(AndroidNotification.newBuilder()
		                                  .setAlert(notification_title)
		                                  .setTitle(notification_title)
		                                  //此字段为透传字段，不会显示在通知栏。用户可以通过此字段来做一些定制需求，如特定的key传要指定跳转的页面（value）
		                                  .addExtra("androidNotification extras key",extrasparam)
		                                  .build())
		                          .build()
		                  )
		                  //Platform指定了哪些平台就会像指定平台中符合推送条件的设备进行推送。 jpush的自定义消息，
		                  // sdk默认不做任何处理，不会有通知提示。建议看文档http://docs.jpush.io/guideline/faq/的
		                  // [通知与自定义消息有什么区别？]了解通知和自定义消息的区别
		                  .setMessage(Message.newBuilder()
		                          .setMsgContent(msg_content)
		                          .setTitle(msg_title)
		                          .addExtra("message extras key",extrasparam)
		                          .build())
		   
		                  .setOptions(Options.newBuilder()
		                          //此字段的值是用来指定本推送要推送的apns环境，false表示开发，true表示生产；对android和自定义消息无意义
		                          .setApnsProduction(false)
		                          //此字段是给开发者自己给推送编号，方便推送者分辨推送记录
		                          .setSendno(1)
		                          //此字段的值是用来指定本推送的离线保存时长，如果不传此字段则默认保存一天，最多指定保留十天，单位为秒
		                          .setTimeToLive(86400)
		                          .build())
		                  .build();
	}

	/**
	 * 构建推送到android 和 ios 设备
	 * @param notification_title
	 * @param msg_title
	 * @param msg_content
	 * @param extrasparam
	 * @return
	 */
	private static PushPayload buildPushObject_android_and_ios(String notification_title, String msg_title,
			String msg_content, String extrasparam) {
			return PushPayload.newBuilder()
				                .setPlatform(Platform.android_ios())
				                .setAudience(Audience.all())
				                 .setNotification(Notification.newBuilder()
				                         .setAlert(notification_title)
				                         .addPlatformNotification(AndroidNotification.newBuilder()
				                                 .setAlert(notification_title)
				                                 .setTitle(notification_title)
				                                 //此字段为透传字段，不会显示在通知栏。用户可以通过此字段来做一些定制需求，如特定的key传要指定跳转的页面（value）
				                                 .addExtra("androidNotification extras key",extrasparam)
				                                 .build()
				                         )
				                         .addPlatformNotification(IosNotification.newBuilder()
				                                 //传一个IosAlert对象，指定apns title、title、subtitle等
				                                 .setAlert(notification_title)
				                                 //直接传alert
				                                 //此项是指定此推送的badge自动加1
				                                 .incrBadge(1)
				                                 //此字段的值default表示系统默认声音；传sound.caf表示此推送以项目里面打包的sound.caf声音来提醒，
				                                 // 如果系统没有此音频则以系统默认声音提醒；此字段如果传空字符串，iOS9及以上的系统是无声音提醒，以下的系统是默认声音
				                                 .setSound("sound.caf")
				                                 //此字段为透传字段，不会显示在通知栏。用户可以通过此字段来做一些定制需求，如特定的key传要指定跳转的页面（value）
				                                 .addExtra("iosNotification extras key",extrasparam)
				                                 //此项说明此推送是一个background推送，想了解background看：http://docs.jpush.io/client/ios_tutorials/#ios-7-background-remote-notification
				                                 // .setContentAvailable(true)
				  
				                                 .build()
				                         )
				                         .build()
				                 )
				                 //Platform指定了哪些平台就会像指定平台中符合推送条件的设备进行推送。 jpush的自定义消息，
				                 // sdk默认不做任何处理，不会有通知提示。建议看文档http://docs.jpush.io/guideline/faq/的
				                 // [通知与自定义消息有什么区别？]了解通知和自定义消息的区别
				                 .setMessage(Message.newBuilder()
				                         .setMsgContent(msg_content)
				                         .setTitle(msg_title)
				                         .addExtra("message extras key",extrasparam)
				                         .build())
				  
				                 .setOptions(Options.newBuilder()
				                         //此字段的值是用来指定本推送要推送的apns环境，false表示开发，true表示生产；对android和自定义消息无意义
				                         .setApnsProduction(false)
				                         //此字段是给开发者自己给推送编号，方便推送者分辨推送记录
				                         .setSendno(1)
				                         //此字段的值是用来指定本推送的离线保存时长，如果不传此字段则默认保存一天，最多指定保留十天，单位为秒
				                         .setTimeToLive(86400)
				                         .build()
				                 )
				                 .build();
	}
	/**
	 * 构建推送到所有对象
	 * @param registrationId
	 * @param notification_title
	 * @param msg_title
	 * @param msg_content
	 * @param extrasparam
	 * @return
	 */
	private static PushPayload buildPushObject_all_registrationId_alertWithTitle(
			String registrationId,
			String notification_title, 
			String msg_title, 
			String msg_content, 
			String extrasparam
		)
	{
		System.out.println("-----------buildPushObject_all_all_alert");
		
		PushPayload payload=PushPayload.newBuilder()
			//指定要推送的平台,all代表当前应用配置了的所有平台，也可以传android等具体平台
			.setPlatform(Platform.all())
			//指定推送的接收对象，all代表所有人，也可以指定已经设置成功的tag或alias或该应应用客户端调用接口获取到的registration id
			.setAudience(Audience.registrationId(registrationId))
			//jpush的通知，android的由jpush直接下发，iOS的由apns服务器下发，Winphone的由mpns下发
			.setNotification(Notification.newBuilder()
					.addPlatformNotification(AndroidNotification.newBuilder()
										.setAlert(notification_title)
										.setTitle(notification_title)
										//此字段为透传字段，不会显示在通知栏。用户可以通过此字段来做一些定制需求，如特定的key传要指定跳转的页面（value）
										.addExtra("androidNotification extras key", extrasparam)
										.build())
					//指定当前推送的iOS通知
					.addPlatformNotification(IosNotification.newBuilder()
							//传一个IosAlert对象，指定apns title、title、subtitle等
										.setAlert(notification_title)
										 //直接传alert,此项是指定此推送的badge自动加1
										.incrBadge(1)
										//此字段的值default表示系统默认声音；传sound.caf表示此推送以项目里面打包的sound.caf声音来提醒，
									    // 如果系统没有此音频则以系统默认声音提醒；此字段如果传空字符串，iOS9及以上的系统是无声音提醒，以下的系统是默认声音
										.setSound("sound.caf")
										//此字段为透传字段，不会显示在通知栏。用户可以通过此字段来做一些定制需求，如特定的key传要指定跳转的页面（value）
										.addExtra("iosNotification extras key",extrasparam)
										  //取消此注释，消息推送时ios将无法在锁屏情况接收
										// .setContentAvailable(true)))
										.build())
					.build())
			//Platform指定了哪些平台就会像指定平台中符合推送条件的设备进行推送。 jpush的自定义消息，
			// sdk默认不做任何处理，不会有通知提示。建议看文档http://docs.jpush.io/guideline/faq/的
			// [通知与自定义消息有什么区别？]了解通知和自定义消息的区别
			.setMessage(Message.newBuilder()
					.setMsgContent(msg_content)
					.setTitle(msg_title)
					.addExtra("message extras key", extrasparam)
					.build())
			.setOptions(Options.newBuilder()
					//此字段的值是用来指定本推送要推送的apns环境，false表示开发，true表示生产；对android和自定义消息无意义
						.setApnsProduction(false)
						//此字段是给开发者自己给推送编号，方便推送者分辨推送记录
						.setSendno(1)
						 //此字段的值是用来指定本推送的离线保存时长，如果不传此字段则默认保存一天，最多指定保留十天；
						.setTimeToLive(86400)
						.build())
			.build();
			
		return payload;
	}
	
	public static void main(String[] args) {
		/**
		if (JpushClientUtil.sendToAllIos("testios", "testjpush","this is a ios dev test", "")==1) {
			System.out.println("success");
		}
		*/
		int result=JpushClientUtil.sendToAllAndroid("testAndroid", "testAndroid","this is a Android dev test", "testing");
		System.out.println("jpush to android result:"+result);
		if (result==1) {
			System.out.println("success"+result);
		}
	}
}
